**![Logo

Description automatically generated](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHkAAAB1CAMAAABd5r4AAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAJDUExURf///97KrcCXXb6WXL+XXNO2i/39/Pz6+Mytf9G0i/j18EVZZgdBaglCaghCaiRQbL2WXMCZYLaUZRVHbbuUXs6whi9NarSTaMCXXJiBY1pgar+XXQNAaAM8ZgM9Z/j4+QY6ZklJguHj6baSXx9Hcfn5+sytgf7+/s7T2YiVqvLr35mDarzCzvv7+8SaXgVAajtafRdHbqmvwIORqAA9aThMecGZYAM+aufp7a6OYrO3w19ukMXK09nDovLy9QY/aAdBabqUXi9OeJylugRBafPz93KCnwQ+Z8nN2dLU3ePm65ijtExsigZAaRlJcBVFbWRzigNBaQhBaQdCagA8Z4aPoyFIdAE9Zr6WW4GPp//+/pV+Zy9OdwZBagU9ZiZPd/Hz9b+XXgM7ahtGaRM9bfb39wI3ZAdAaCBHariSXKCEXgZBaUJVaL+WWwhAabyUXL2VXAQ/aAA0Z3CBmvz8/QI/afPz9Yl2Y35vZL6XXYKLo494ZFdebJumugA2ZQdAauXn7Orh1wExZcCdbJ6DYTJMaGx7l3BpZAE4ZO7v87mTXOXWxIKQqJWkuARAaNve5AdAabWQXTdQZ9W9mAQ8Zr+WXAFAadPV3UdggBVIdv7+/wY8ZyVLa4SSpQAzZwA/amx9k/T19/n29D5ZfQE+avv7/czO2tG4mQY4ZKaIYbK3yiFIatze5XB7ml1uktnCoY59a8moeOrdywVCau7j1drEpFZha+/l2A9CatzGpw1CasajcQ5Eav///v79/Pfy6wAAAAAd6RIAAADBdFJOU////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////wCINFSNAAAACXBIWXMAACHVAAAh1QEEnLSdAAAKWklEQVRoQ+1bPatkxxGdDcwL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) San Francisco Bay University**

**EE488 - Computer Architecture**

**Homework Assignment #7**

**Due day: 4/21/2023**

**Instruction:**

1. **Push the answer sheet to GitHub in word file.**
2. **Overdue homework submission could not be accepted.**
3. **Takes academic honesty and integrity seriously (Zero Tolerance of Cheating & Plagiarism)**
4. (Bonus) Write two Verilog modules to design a 4-bits multiplier which implements Booth’s algorithm and one of multiplication algorithms from 3 versions shown in the handout of *Lec06-alu.pdf,* respectively.

**Answer:**

**Github:** [**https://github.com/KhandokerSamiulHoque/ee488-bonus-assighnemnt-7.git**](https://github.com/KhandokerSamiulHoque/ee488-bonus-assighnemnt-7.git) **1.1**

**Design:**

module boothAlgo\_mul(input [3:0] multiplicand,input [3:0] multiplier,output reg [7:0] product);

reg [4:0] s;

reg [4:0] a;

reg [2:0] i;

always @(\*) begin

s[4:0] = {1'b0, multiplier};

a[4:0] = {1'b0, multiplicand, 2'b0};

product = 0;

for (i = 0; i < 4; i = i + 1) begin

if (s[1:0] == 2'b01)

begin

product = product + a[4:0];

end

else if (s[1:0] == 2'b10) begin

product = product - a[4:0];

end

if (product[0] == 1) begin

s[1:0] = s[1:0] + 2'b10;

end

s[4:1] = s[3:0];

s[0] = a[0];

a[4:1] = a[3:0];

a[0] = product[0];

product = product >> 1;

end

end

endmodule

**Testbench:**

module boothAlgo\_mul\_tb;

reg [3:0] multiplicand;

reg [3:0] multiplier;

wire [7:0] product;

boothAlgo\_mul ee488prob1 (.multiplicand(multiplicand),.multiplier(multiplier),.product(product));

reg clock = 0;

always

#5

clock = ~clock;

initial begin

$dumpfile("boothAlgo\_mul\_tb.vcd");

$dumpvars(0, boothAlgo\_mul\_tb);

multiplicand = 4'b0010;

multiplier = 4'b0011;

#10;

multiplicand = 4'b0010;

multiplier = 4'b0110;

#10;

multiplicand = 4'b0010;

multiplier = 4'b1100;

#10;

multiplicand = 4'b0010;

multiplier = 4'b1000;

#10;

multiplicand = 4'b0010;

multiplier = 4'b0000;

#10;

$finish;

end

always @(posedge clock) begin

$display("multiplicand = %b, multiplier = %b, product = %b", multiplicand, multiplier, product);

end

endmodule **1.2**

**Design:**

module multiplier\_algorithm(input [31:0] multiplicand,input [31:0] multiplier,output reg [63:0] product);

integer i;

always @(\*) begin

product = 0;

for (i = 0; i < 32; i = i + 1) begin

if (product[0]) begin

product[63:32] = product[63:32] + multiplicand;

end

product = {product[62:0], product[63]};

if (multiplier[31 - i]) begin

product[31:0] = product[31:0] + multiplicand;

end

end

end

endmodule

**Testbench:**

module tb\_multiplier\_algorithm;

reg [31:0] multiplicand;

reg [31:0] multiplier;

wire [63:0] product;

multiplier\_algorithm uut(.multiplicand(multiplicand),.multiplier(multiplier),

.product(product));

initial begin

$dumpfile("tb\_multiplier\_algorithm.vcd");

$dumpvars;

$monitor("Time = %t | multiplicand = %h | multiplier = %h | product = %h", $time, multiplicand, multiplier, product);

multiplicand = 32'h00000001;

multiplier = 32'h00000011;

#10;

multiplicand = 32'h00000011;

multiplier = 32'h00000101;

#10;

multiplicand = 32'h00000000;

multiplier = 32'h00001100;

#10;

$finish;

end

endmodule

1. (Bonus) Write two Verilog modules to design a 4-bits divisor which implements any two of division algorithms from 3 versions shown in the handout of *Lec07-division.pdf,* respectively.

**Answer:  
  
2.1**

**Design:**

module divisor\_met1 (input clk,input [3:0] dividend,input [3:0] divisor,input start,output [3:0] quotient,output [3:0] remainder,output out);

reg [3:0] dividend\_reg, divisor\_reg, quotient\_reg;

reg [2:0] counter;

reg [4:0] adder\_out;

always @(posedge clk) begin

if (start) begin

dividend\_reg <= {dividend, 4'b0};

divisor\_reg <= {divisor, 4'b0};

quotient\_reg <= 4'b0;

counter <= 3'b0;

adder\_out <= 4'b0;

end

else if (counter < 4)

begin

adder\_out <= dividend\_reg + (~divisor\_reg + 1);

if (adder\_out[3] == 1)

begin

quotient\_reg[counter] <= 0;

adder\_out <= adder\_out + divisor\_reg;

end else

begin

quotient\_reg[counter] <= 1;

end

dividend\_reg <= adder\_out[3:0];

counter <= counter + 1;

end

end

assign quotient = quotient\_reg;

assign remainder = dividend\_reg[3:0];

assign out = (counter == 4);

endmodule

**Testbench:**module divisor\_met1\_tb;

reg clk;

reg [3:0] dividend;

reg [3:0] divisor;

reg start;

wire [3:0] quotient;

wire [3:0] remainder;

wire out;

divisor\_met1 ee488prob2.1 (.clk(clk),.dividend(dividend),.divisor(divisor),.start(start),.quotient(quotient),.remainder(remainder),

.out(out)

);

initial begin

$dumpfile("divisor\_met1\_tb.vcd");

$dumpvars(0,divisor\_met1\_tb);

clk = 0;

dividend = 4'b1010;

divisor = 4'b1101;

start = 0;

#10

start = 1;

#10

start = 0;

#20

dividend = 4'b0000;

#20

divisor = 4'b0000;

#100

$finish;

end

always

#5

clk = ~clk;

endmodule

**2.2**

**Design:**

module divisor\_meth(input [3:0] dividend,input [3:0] divisor,output reg [3:0] quotient);

reg [3:0] remainder;

integer i;

always @(\*) begin

quotient = 4'b0000;

remainder = dividend;

for (i = 3; i >= 0; i = i-1) begin

remainder = remainder << 1;

quotient[i] = remainder >= divisor;

if (quotient[i]) remainder = remainder - divisor;

end

end

endmodule

**Testbench:**

module divisor\_meth\_tb();

reg [3:0] dividend;

reg [3:0] divisor;

wire [3:0] quotient;

integer i;

divider\_meth ee488prob2\_2 (.dividend(dividend),.divisor(divisor),.quotient(quotient));

initial begin

$dumpfile("divisor\_meth\_tb.vcd");

$dumpvars(0, divisor\_meth\_tb);

dividend = 4'b0011;

divisor = 4'b0101;

#10;

$display("Dividend: %d", dividend);

$display("Divisor: %d", divisor);

#10;

$display("Quotient: %d", quotient);

#10;

$display("%d / %d = %d", dividend, divisor, dividend / divisor);

#10

reg [3:0] verify\_quotient = 4'b0000;

reg [3:0] remainder = dividend;

for (i = 3; i >= 0; i = i-1) begin

remainder = remainder << 1;

verify\_quotient[i] = remainder >= divisor;

if (verify\_quotient[i]) remainder = remainder - divisor;

end

$display("%d / %d = %d (quotient)", dividend, divisor, verify\_quotient);

$display("%d / %d = %d (remainder)", dividend, divisor, remainder);

end

endmodule